草庐IT

goroutine 值返回顺序

全部标签

go - sync.Once.Do 是否保证跨 goroutine 的可见性?

例子here暗示sync.Once.Do保证字符串vara跨goroutines的可见性。如果例如由sync.Once.Do调用的函数f()初始化结构实例的多个字段,是否也是如此?在没有任何额外同步的情况下,结构实例的所有字段是否对其他goroutine可见? 最佳答案 让我们分解一下example:变量a在函数setup()返回之前设置,因为在单个goroutine中的读取和写入必须表现得好像它们已执行按照程序指定的顺序[1].once.Do()对setup()的单次调用发生在once.Do()的任何调用之前返回[2].因此,a变

json - Golang json解码返回空

这个问题在这里已经有了答案:JSONanddealingwithunexportedfields(2个答案)关闭4年前。有人可以向我解释为什么这段代码无法正确解码json吗:packagemainimport("fmt""os""log""encoding/json")typeConfigstruct{mongoConnectionStringstring`json:"database"`Elasticstruct{mainstring`json:"main"`logstring`json:"log"`}`json:"elastic"`logFilePathstring`json:"l

go - golang 的 GC 会释放仅由 goroutine 引用的对象的内存吗?

m:=map[string]*Object{"a":obj}gofunc(obj*Object){obj.Do()}(m["a"])delete(m,"a")当obj.Do()没有完成时,GC会释放obj的内存吗? 最佳答案 代码会求值m["a"]这会给出指针obj,然后obj会被放​​到goroutine的一个新栈上,然后goroutine会从那个栈开始,然后obj会从原来goroutine中的map中移除。那时新的goroutine堆栈将有一个指向obj的指针,因此在第二个goroutine完成执行之前,obj不会因为这个原因而

pointers - 您可以将多个值中的部分或全部作为函数的指针返回吗?

在使用Go时,我遇到了各种错误,试图在返回另一个值的同时返回一个字符串作为指针。像这样的东西(请原谅这不是运行代码,我只是写它来了解我想做什么,因为我不知道如何让它工作):funcA(sstring)*string,int{//Stuffreturn&a,b}*c,d:=A("Hithere.")当我尝试各种组合say时,将字符串(var.a)作为指针返回时,我遇到了各种错误。这很简单,有许多返回单个变量的示例,但我不确定是否可以使用多个返回值。抱歉,如果这看起来是一个非常基本的问题,我仍然在思考Go。 最佳答案 如前所述here在

使用带有选择的 channel 时的 Goroutine 死锁

我试图重写一个没有使用select或WaitGroup的工作程序,以便它可以实现select和WaitGroup,但我遇到了一个问题,我找不到解决方案。看起来goroutinedeadlock发生了,因为Manager函数没有从writerchannel中获取数据,因此该channel被阻止发送/接收并且程序锁定。原始的Manager函数,没有select:funcManager(list*[]Request,writerChan所以我有一个工作程序,但需要实现WaitGroup和select,有更新的代码:使用select实现的更新的Manager函数:funcManager(lis

尝试附加相同类型的结构时,Go 返回错误

我在尝试使用追加函数合并两个结构时遇到错误:./test.go:33:18:cannotuseconfigs(typeMapUsers)astypestruct{Userarnstring"yaml:\"userarn\"";Usernamestring"yaml:\"username\"";Groups[]string"yaml:\"groups\""}inappend这是代码。packagemainimport("fmt""gopkg.in/yaml.v2""io/ioutil""os")typeMapUsers[]struct{UserarnstringUsernamestrin

loops - 完成 2 个 goroutine 后删除文件

我有一个简单的goroutine,它调用一个本地二进制文件(rsync),它指向一个包含要操作的文件列表的临时文本文件,以及一个目标目录。在例程结束时,我删除了临时文件。这里没有问题。但在某些情况下需要使用相同的临时文件,当在范围循环中调用两个目标时,例如:destDirs:=[]string{"dir1/","dir2/"}for_,dest:=rangedestDirs{golaunchRoutine(tempfile.Name(),dest)}由于launchRoutine可能需要一段时间才能运行,并且由于这是一个网络应用程序,所以等到例程完成是不可取的。问题是,将os.Remo

去死锁所有 goroutines 睡着了

这是我之前帖子的后续:http://stackoverflow.com/questions/34736825/goroutine-exit-status-2-what-does-it-mean-why-is-it-happening?noredirect=1#comment57238789_34736825在阅读了SO内外的多个主题和文章之后,我仍然无法弄清楚应该在哪里关闭channel。该程序将打开一个文件列表,为每个输入文件创建一个输出文件(具有相同的名称),访问每个输入文件中的所有url并从中获取所有href链接-这些链接将保存到相应的输出文件。但是,我收到以下错误:http:/

function - 在单独的 golang 包中声明一个结构不能返回值,但在具体声明时可以

尝试从另一个包中导入一个结构类型,它完美返回,但除非在不使用实例化函数的情况下声明,否则无法找到该结构的值。//Xexecutesandfindsvaluesfine,Zdoesnot.packagemainfuncmain(){x:=&Command{}z:=command.NewCommand()fmt.Println(x.command)fmt.Println(z.command)}packagecommandtypeCommandstruct{//Ourstructureddata/objectforCommandaliasstringcommandstringverboseb

go - 我可以使用指向 "error"的指针来捕获返回错误吗?

我正在编写一些事务开始/提交/回滚函数,我想将block配对以防止忘记提交我是这样写的:func(foo*Foo)Bar()(errerror){foo.Begin()deferfoo.End(&err)//somebusinesscodereturn}func(foo*Foo)End(eptr*error){//ifrecoverifr:=recover();r!=nil{debug.PrintStack()*eptr=r.(error)}varerr=*eptriferr!=nil{foo.Rollback()}else{foo.Commit()}}它有效,但它使用“接口(inte